package com.markedquilt.SwordForOffer;
//给定一个数组 nums 和滑动窗口的大小 k，请找出所有滑动窗口里的最大值。
//
// 示例:
//
// 输入: nums = [1,3,-1,-3,5,3,6,7], 和 k = 3
//输出: [3,3,5,5,6,7]
//解释:
//
//  滑动窗口的位置                最大值
//---------------               -----
//[1  3  -1] -3  5  3  6  7       3
// 1 [3  -1  -3] 5  3  6  7       3
// 1  3 [-1  -3  5] 3  6  7       5
// 1  3  -1 [-3  5  3] 6  7       5
// 1  3  -1  -3 [5  3  6] 7       6
// 1  3  -1  -3  5 [3  6  7]      7
//
//
//
// 提示：
//
// 你可以假设 k 总是有效的，在输入数组不为空的情况下，1 ≤ k ≤ 输入数组的大小。
//
// 注意：本题与主站 239 题相同：https://leetcode-cn.com/problems/sliding-window-maximum/
// Related Topics 队列 Sliding Window
// 👍 140 👎 0

import java.util.Arrays;

/**
 * Title:
 * Project: LeetcodeProblem
 *
 * @author ZhangKe
 * Created on 2020/11/4
 */
public class _maxSlidingWindow {

    public static int[] maxSlidingWindow(int[] nums, int k) {
        if (nums.length==0){
            return new int[]{};
        }
        int[] result = new int[nums.length - k+1];
        int cursor = 0,tail=k-1;
        for (int i = 0; i <= nums.length-k; i++) {
            int max=nums[i];
            for (int j = 0; j <= tail - i; j++) {
                if (max < nums[i+j]) {
                    max = nums[i + j];
                }
            }
            result[cursor++] = max;
            tail++;
        }
        return result;
    }

    public static void main(String[] args) {
        //1,3,-1,-3,5,3,6,7
        int test[] = {};
        System.out.println(Arrays.toString(maxSlidingWindow(test, 3)));
    }
}
